package com.example.onlinemusic.controller;

import com.example.onlinemusic.mapper.UserMapper;
import com.example.onlinemusic.model.User;
import com.example.onlinemusic.tools.Constant;
import com.example.onlinemusic.tools.ResponseBodyMessage;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import javax.servlet.http.HttpServletRequest;

/**
 * \* Created with IntelliJ IDEA.
 * \* User: Administrator
 * \* Date: 2022/7/25
 * \* Time: 14:13
 * \* To change this template use File | Settings | File Templates.
 * \* Description:
 * \
 */
@RestController
@RequestMapping("/user")
public class UserController {
    @Autowired
    private UserMapper userMapper;

    @Autowired
    private BCryptPasswordEncoder bCryptPasswordEncoder ;


    @RequestMapping("/login1")
    public ResponseBodyMessage<User> login1(@RequestParam String username,@RequestParam String password,
                                        HttpServletRequest request){
        User userLogin = new User();
        userLogin.setUsername(username);
        userLogin.setPassword(password);


        User user = userMapper.login(userLogin);
        if(user == null){
            System.out.println("登录失败");
            return new ResponseBodyMessage<>(-1,"登录失败！",userLogin);
        }else{
            //request.getSession().setAttribute("USERINFO_SESSION_KEY",user);
            request.getSession().setAttribute(Constant.USERINFO_SESSION_KEY,user);
            return  new ResponseBodyMessage<>(0,"登录成功！",userLogin);
        }

    }

    @RequestMapping("/login")
    public ResponseBodyMessage<User> login(@RequestParam String username,@RequestParam String password,
                                           HttpServletRequest request){
       /* User userLogin = new User();
        userLogin.setUsername(username);
        userLogin.setPassword(password);
        User user = userMapper.login(userLogin);*/

        User user = userMapper.selectByName(username);

        if(user == null){
            System.out.println("登录失败");
            return new ResponseBodyMessage<>(-1,"登录失败！",user);
        }else{
            boolean flag = bCryptPasswordEncoder.matches(password,user.getPassword());
            if(!flag){
                return new ResponseBodyMessage<>(-1,"用户名或密码错误！",user);
            }
            //request.getSession().setAttribute("USERINFO_SESSION_KEY",user);
            request.getSession().setAttribute(Constant.USERINFO_SESSION_KEY,user);
            return  new ResponseBodyMessage<>(0,"登录成功！",user);
        }

    }
}
